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(57) A network (4) includes optical routers (19), 
which route information in fibers (10). Each fiber carries 
a plurality of data channels (16), carrying data in data 
bursts (28) and a control channel, carrying control infor- 
mation in burst header packets (32). A burst header 
packet includes routing information for an associated 
data burst (28) and precedes its associated data burst. 
Information on the data channels and control channel is 
organized in synchronized slots. Multiple burst header 
packets occupy portions of a slot, referred to as micro- 
slots. When the burst header packets are received, an 
egress processor (52) schedules the routing of their as- 
sociated bursts. The egress processor (52) determines 
a time at which a data burst can be scheduled for pass- 
ing through an optical matrix (40) to the desired output 
channel group (the burst can be delayed via fiber delay 
lines (46) if necessary). 
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Description 

BACKGROUND OF THE INVENTION 
5 1. TECHNICAL FIELD 

[0001] This invention relates in general to telecommunications and, more particularly, to a method and apparatus 
for optical switching. 

w 2. DESCRIPTION OF THE RELATED ART 

[0002] Data traffic over networks, particularly the Internet, has increased dramatically recently, and will continue as 
the user increase and new services requiring more bandwidth are introduced. The increase in Internet traffic requires 
a network with high capacity routers capable of routing data packets of variable length. One option is the use of optical 
15 networks. 

[0003] The emergence of dense-wavelength division multiplexing (DWDM) technology has improved the bandwidth 
problem by increasing the capacity of an optical fiber. However, the increased capacity creates a serious mismatch 
with current electronic switching technologies that are capable of switching data rates up to a few gigabits per second, 
as opposed to the multiple terabit per second capability of DWDM. While emerging ATM switches and IP routers can 

20 be used to switch data using the individual channels within a fiber, typically at 2.4 gigabits per second or ten gigabits 
per second, this approach implies that tens or hundreds of switch interfaces must be used to terminate a single DWDM 
fiber with a large number of channels. This could lead to a significant loss of statistical multiplexing efficiency when 
the parallel channels are used simply as a collection of independent links, rather than as a shared resource. 
[0004] Different approaches advocating the use of optical technology in place of electronics in switching systems 

25 have been proposed; however, the limitations of optical component technology has largely limited optical switching to 
facility management/control applications. One approach, called optical burst-switched networking, attempts to make 
the best use of optical and electronic switching technologies. The electronics provides dynamic control of system 
resources by assigning individual user data bursts to channels of a DWDM fiber, while optical technology is used to 
switch the user data channels entirely in the optical domain. 

30 [0005] Previous optical burst-switched networks designed to directly handle end-to-end user data channels have 
been disappointing and have shown the limitations of current optical components. 
[0006] Therefore, a need has arisen for a method and apparatus for providing a burst-switched network. 

BRIEF SUMMARY OF THE INVENTION 

35 

[0007] In the present invention, a method and apparatus for scheduling the switching of data burst through a router 
in an optical burst switched network is shown, wherein data bursts are received by the router over a first set of plurality 
of optical transmission lines and are switched to a second set of optical transmission lines. The data bursts are com- 
municated over the first and second sets of optical transmission lines over multiple channels using synchronous fixed 

40 length slots, each burst occupying one or more slots in a channel. Current scheduling bit patterns are generated for 
respective outgoing channels indicating which slots in each outgoing channel are already scheduled to transmit a data 
burst within a predetermined time window relative to a current time point. An incoming burst bit sequence is generated 
for an incoming burst indicating which slots within the predetermined time window would be occupied by the incoming 
burst relative to a current time point. The incoming burst bit sequence is compared with the current scheduling bit 

45 patterns to determine whether the incoming burst can be scheduled for transmission on one of the outgoing channels. 
[0008] The present invention provides an efficient and flexible architecture for switching data bursts. 

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS 

so [0009] For a more complete understanding of the present invention, and the advantages thereof, reference is now 
made to the following descriptions taken in conjunction with the accompanying drawings, in which: 

Figure 1 is a block diagram of an optical network; 

55 Figure 2 illustrates concepts of data bust and BHP; 

Figure 3 illustrates concepts of slot, data slot, control slot, micro-slot and optical data burst; 
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Figure 4 illustrate a block diagram of optical router when BHPs are transmitted as Out-Band; 
Figure 5 is a timing diagram showing BHPs transmitted as out-band; 
5 Figure 6 illustrates a block diagram of an optical switch matrix; 

Figure 7 illustrates a block diagram of the electric control of an optical router; 

Figure 8 illustrates a timing diagram showing maximum and minimum arrival times for a burst relative to its header; 

w 

Figure 9 illustrates a timing diagram showing a Slot Sequence Window (SSW); 
Figure 10 illustrates a timing diagram showing shifting of a SSW; 
15 Figure 1 1 illustrates an example of scheduling bursts; 

Figure 12 illustrates a Fiber Delay Line Entry Status Window (FESW); 
Figure 13 illustrates a Micro-Slot Status Window (MSSW); 

20 

Figure 14 illustrates the relationship between the SSW, FESW and MSSW; 
Figure 15 illustrates a flow diagram describing the scheduling method; 
25 Figure 1 6 illustrates a diagram showing the finite number of burst bit patterns; 

Figure 17 illustrates combination logic for matching within a SSW; 
Figure 18 is a block diagram of an egress scheduler; 

30 

Figure 19 illustrates a block diagram of protocol processing stages; 
Figure 20 illustrates the fields for a slot of information in a Common Slot Format; 
35 Figure 21 illustrates the fields for Service Specific Slot Layer for a data channel; 

Figure 22 illustrates a payload of a Service Specific Slot Layer for a control channel; 
Figure 23 illustrates a Service Specific Slot Layer preamble for a control channel; 

40 

Figure 24 illustrates the transmission of burst header packets and control packets; 
Figure 25 illustrates a burst header; 
45 Figure 26 illustrates a sub-packet of a burst; 

Figure 27 illustrates format of a super packet; 
Figure 28 illustrates transmission of a burst; 

50 

Figure 29 illustrates the fields of a BHP micro-slot; 
Figure 30 illustrates the fields of a BHP payload; 
55 Figure 31 illustrates the fields of a control packet; 

Figure 32 illustrates in-band transmission of bursts and BHPs; and 
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Figure 33 illustrates a block diagram of an I/O circuit for in-band transmission. 

DETAILED DESCRIPTION OF THE INVENTION 

5 [0010] The present invention is best understood in relation to Figures 1 -33 of the drawings, like numerals being used 
for like elements of the various drawings. 

[0011] Figure 1 illustrates a general block diagram of an optical switched network 4. The optical switched network 
4 includes multiple electronic ingress edge routers 6 and multiple egress edge routers 8. The ingress edge routers 6 
and egress edge routers 8 are coupled to multiple core routers 10. The connections between ingress edge routers 6, 
10 egress edge routers 8 and core routers 1 0 are made using optical links 12. Each optical fiber can carry multiple channels 
of optical data. 

[0012] In operation, a data burst (or simply "burst") of optical data is the basic data block to be transferred through 
the network 4. Ingress edge routers and egress edge routers are responsible for burst assembly and disassembly 
functions, and serve as legacy interfaces between the optical switched network 4 and conventional electronic routers. 

15 [001 3] As in Figure 2, a burst 28 will not be terminated electronically when it is transmitted across a hop within network 
4. It will "fly" across the network. In order to guide the "flying" course, a companion Burst Header Packet (BHP) 34 is 
transmitted prior to the departure of a data burst at previous hop. The BHP of an optical burst would contain network 
protocol header such as IP (Internet Protocol). In also contains information to describe its coupled optical data burst 
such as when it will arrive, in which channel it would arrive, and what is its length. This is to describe the temporal and 

20 spatial position of the associated optical burst relative to the temporal and spatial position of the BHP itself. 

[0014] As in Figure 3, this invention assumes that both optical data bursts 28-and BHPs 32 are transmitted in syn- 
chronous fixed length slots 30. A slot 30 used to transmit an optical burst is referred to as a data slot 29. At least one 
data slot will be needed to transmit a burst. The consecutive sequence of data slots (at least one) that are used to 
transmit one burst is referred as a Slot Session (SS). 

25 [0015] Slots that are used to transmit BHPs and other network Control Packets (CPs) are called control slots 31 . To 
transmit BHPs and CPs, a control slot 31 is divided into Micro-slots 34. One BHP 32 uses one micro-slot 34. One CP 
would use at least one micro-slot. The consecutive sequence of micro-slots that are used to transmit a CP is referred 
as a Micro-Slot Session (MSS). 

[0016] There are many possible ways to frame the transmission of data and control slots. A fundamental feature is 
30 whether BHPs are transmitted as In-Band or as Out-Band. When transmitted as In-Band, BHPs are always transported 
in the same DWDM (Dense Wavelength Division Multiplexing) channel as its associated burst is (see Figure 32). When 
transmitted as Out-Band, BHPs are transmitted in a separate control channel that may provide BHPs transportation 
for a group of DWDM channels. Figure 4 is a general block diagram of a burst switching based optical core router 1 0 
using Out-Band BHP transmission. Optical fibers 12 carrying one or more channel groups 26 (incoming) or 27 (outgo- 
35 ing), with each channel group 26 or 27 including a control channel 17 (incoming) or 18 (outgoing) and a group of 
multiplexed data channels 16 (incoming) or 21 (outgoing). Incoming channel groups 26 are received by the ingress of 
I/O cards 14. At ingress, the ingress of I/O cards 1 4 separate the incoming data channels 16 and the incoming control 
channel 1 7 of the incoming channel group 26. It then sends the separated channels to switch 1 9 . The incoming control 
channel 1 7 is sent to the electronic control 20 of switch 1 9 and the incoming data channels 1 6 are sent to optical switch 
40 22 of switch 1 9. The electronic control 20, responsive to information from the incoming control channels 1 7, controls 
the path of bursts from on the incoming data channels 1 6 to a desired outgoing data channel 21 . At egress, an outgoing 
control channel 18 and outgoing data channels 21 of an outgoing channel group 27 are sent to an egress of an I/O 
card 24, and be united and sent out through fiber 12. 

[0017] Figure 5 illustrates transmission of data slots 29 and control slots 31 in a fiber 1 2 when BHPs are transmitted 
45 as Out-Band. DWDM channels in a fiber 1 2 are grouped together as channel groups 26 or 27. A channel group 26 or 
27 includes one control channel 17 or 18 and a number of data channels 16 or 21. Each data channel carries data 
slots 29 that transmit bursts 28 by slot session. Each control channel carries control slots 31 that use micro-slots 34 
to transmit BHPs 32 and CPs. 

[0018] When data bursts 28 and their BHPs 32 are transmitted in this fashion, the number of micro-slots 34 within 
so a control slot 31 will be a deterministic factorfor burst arrival rate, since no burst 28 can arrive without an earlier-arriving 
BHP 34. Assuming that the average burst length in number of slots 30 is denoted by BL, the channel slot rate is R slot 
the number of data channels 1 6 or 21 in a channel group 26 or 27 is N, and the number of micro-slot in one slot is T|, 
then there must be: 

ff sbU d j + fl s/oi. d2 + - • ' + fl stof. dN 
T ) X "s/of^c- BL 
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[0019] Assuming that all data channels and the control channel have the same channel slot rate, then: 

r\ x BL> N (1) 

5 

[0020] This equation reflects the trade-off between channel group size, slot size, micro-slot size and burst size. For 
example, if 1 6 micro-slots (BHPs) are transmitted within a slot, and if the average burst length is two slots, then a fiber 
can support up to 32 data channels. Since BL=2 is a modest assumption, the above slotted transmission would not 
be a limitation for burst arrival rate. 

w [0021 ] In the following, the above transmission architecture will be used to illustrate the embodiment; the developed 
traffic model and method are, however, not limited to this architecture. For purposes of clarity, T n + refers to a time after 
and near T n ,and T n - refers to a time preceding and near T n . The T n slot" refers to the time duration from T n + to T n+1 -. 
[0022] Referring to Figure 4 and Figure 5, the basic operation of the router 1 0 will be discussed. Data bursts 28 of 
optical information are received at the inputs of optical switch 22. For each data burst 28, the associated BHP 32 arrives 

15 jn a preceding control slot 31 . The BHP, which contains the information defining the desired routing of it associated 
burst, is converted to electronic form. The information in the BHP is used by the electronic control 20 to configure the 
optical switch 22 prior to the arrival of the data burst 28. When the data burst arrives, the optical matrix 22 is already 
configured to switch the burst 28 to the proper desired outgoing data channel 21 or to fiber delay line as described in 
greater detail below. Accordingly, the bursts 28 can be switched through router 1 0 without conversion of the burst data 

20 into electrical form. The BHPs 32 are converted back into optical form and reunited with their associated data burst 28 
in the egress of I/O card 24. The BHP 32 must continue ahead of the burst 28 in order for switching to occur in the 
optical domain. 

[0023] Figure 6 illustrates a more detailed block diagram of the optical switch 22. Optical switch 22 includes optical 
matrix 40, having input ports 42 and output ports 44. One or more fiber delay lines (FDLs) 46 are coupled between 
25 certain input ports and output ports, and there are multiple possible delay values. This invention assumes that the 
basic delay value x is the same as one slot 30 duration, and a delay value of a FDL is always an integral numbers of 
the basic delay x. Multiple delay lines 46 may be assigned to some delay values. For example, there may be five 1x 
delay lines and five 2x delay lines. The remainder of the input ports 42 and output ports 44 are coupled to individual 
data channels from fibers 12. 

30 [0024] In operation, the electronic control 20 sets the paths (from an input port 42 to an output port 44) through the 
optical matrix 40. Each incoming data channel 16 is coupled to an input port 42 and each outgoing data channel 21 is 
coupled to an output port 44. Generally speaking, an incoming data burst 28 may be switched to any available output 
port 44. The associated BHP 32 will indicate a specific output channel group 27 as the destination. The electronic 
control 20 will find an available output data channel on the outgoing channel group 27 and direct the data burst 28 to 

35 that data channel. 

[0025] In some cases, it is desirable to delay a data burst prior to sending it to a data channel. This may occur, for 
example, if no data channel is currently available on the selected output port 24. In this case, the data burst 28 is 
directed to an output port 44 connected to a delay line 46. The burst will travel through the delay line and be reconnected 
at the input port 42 coupled to the delay line 46. Once the data burst 28 has emerged from the delay line 46, the optical 

40 matrix 40 switches the corresponding input port 42 to the output port 44 of the desired outgoing data channel 21 . 
Hence, the optical data can be delayed for a short period of time without any conversion to the electrical domain. 
[0026] Figure 7 illustrates a more specific block diagram of the electronic control circuitry 20. The electronic control 
circuitry 20 includes ingress processors 50 for each incoming control channel 17, egress schedulers 52 for each out- 
going control channel 1 8 and an electronic matrix 54 for connecting any ingress processor 50 to any egress processor 

45 52. 

[0027] In operation, when a BHP 32 arrives on an incoming control channel 17, it is processed by the electronic 
control circuitry 20. The ingress processing 50 and the electronic matrix 54 of the electronic control circuitry 20 handle 
the traditional packet forwarding and routing functions of a router. Accordingly, the ingress functions convert the optical 
BHPs 32 into electrical BHPs 32. Each BHP contains the destination information that defines the desired output channel 
so group 27 for the associated packet. Based on this information, the BHP is routed through the electronic matrix to the 
correct egress scheduler 54. 

[0028] There is a complete overlap between optica! matrix output channel group and electronic matrix output port, 
and there is an egress scheduler 52 for every electronic matrix output port. An egress scheduler 52 handles the requests 
of the BHPs that have been forwarded to it, as described in greater detail below. For purpose of this specification, a 
55 slotted scheduling method is presented. 

[0029] Figure 8 illustrates a timing diagram showing minimum A mjn and maximum A max arrival time of bursts 28 
relative to their BHPs 32. A mln and A max are both described in terms of slots. Hence, in Figure 8, A mjn =2x and A max =1 0t. 
The values of A mjn and A^ are depending upon system design factors such as burst loss rate, burst delay and so 
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on. Figure 9 illustrates how burst loads for a channel are modeled. In the illustrated embodiment, the burst load for 
each data channel of an output fiber is modeled based on A^, A max , and delays attributable to the fiber delay lines 
(FDLs) 46. As described above, the basic fiber delay line unitx, which is the same as a slot time period, and the delaying 
time units of the cascaded output of a fiber delay line will be always an integer number times the basic unit x. The 

5 maximum possible delay through a fiber delay line 46 is denoted as D max . 

[0030] When a slot with data (sltj) arrives at optical switching matrix 40, it can be switched to an output either imme- 
diately or D k slot time periods later. In this model, a vector dtt={D 0> D 1$ D 2 ,..„ D k ) denotes the possible delay values, 
where D 0 is defined as no delay and D k means a k slot duration delay. For each delay value D k , there may be multiple 
delay lines. The number (m) of delay lines can be different for each delay value D k . Fore example, there could be three 

10 D 1 delay lines 46, two D 2 delay lines 46 and two D 3 delay lines 46. The number of entries to FDL is normally not equal 
to the number of input or output channels. In Figure 4, there are N channels, and m fiber delay lines 46. 
[0031] In burst switching, traffic will be distributed to output channels by bursts 28, which may occupy multiple slots 
30. A burst 28 has variable number of slots, and various arrival times relative to its BHP 32. Therefore, the distribution 
of bursts to output channels becomes a problem, since the availability of both an output channel on the desired output 

is fiber and a fiber delay line 46 becomes dependent upon previous transmitted bursts. 

[0032] To increase the efficiency of scheduling the switching of bursts, a discrete time model for the burst load up to 
the maximum delay of a channel is provided. In order to model the loading condition of a channel, time window is 
defined, referred to herein as the Slot Sequence Window (SSW), shown in Figure 9. The SSW contains a fix length 
sequence of discrete time points T 0 , T 1t ..., T m . For every 7} G SSW, T M is called its predecessor, and T i+1 is called its 

20 successor. The start of the sequence also called S point, has no predecessor, and the end of the sequence T m , 
also called M point, has no successor. The S point is defined as the time at which the BHP 32 of a burst 28 arrives at 
the traffic scheduler 52 of an outgoing channel group 27 . The A max point (Figure 8) is the maximum time offset from 
S point for the burst arrival time at the optical matrix 40. The A mln point defines the minimum time offset from S point 
for the burst arrival time at the optical matrix 40. The M point is the maximum delay (D max ) from the A max point for the 

25 burst that can be provided by a fiber delay line 46, once the burst 28 has reached the optical matrix 40. 

[0033] Many system actions are defined in association with the time points within the sequence. A burst brst has 
"arrived" at point T t if at T r it may have not arrived, but at T h it would have arrived. A burst brst has "left" point 7) if at 
T h it may still be with the system, but at T h it would have left. A time point T t has been "occupied" if the period from 
to T j+1 . has been assigned to an incoming burst, otherwise the time point is "empty" ■ 

30 [0034] A variable E is used to denote that if a time point 7/ is empty or occupied. If 7;.E=f, 7} is empty, otherwise if 
Tj.E=0, Tj is occupied. Therefore, a SSW has a corresponding "E-list" composed of the value of the E variable of the 
time points. An E-list denotes that which time point of SSW is empty, and which has been occupied. The M point has 
one more variable denoted as the "M-counter". The M-counter is used in cases where the Mpoint is occupied; it counts 
the number of slots cycles before M point becomes empty again. In other words, the M-counter counts the number of 

35 slots of a burst 28 that lie outside of the SSW. 

[0035] Since all the time points in SSW are relative to the S point, and the S point is a BHP's arrival time, properties 
defined in SSW are BHP arrival time specific. Therefore, even if two bursts arrive at the same time, as long as their 
BHPs arrive at different times, they see different SSI/Vwindows. Similarly, if two bursts arrive at different times, as long 
as their BHPs arrive at the same time, they have the same SSW windows. 

40 [0036] When a BHP arrives at the channel scheduler 52, the effects of all the previous bursts' transmission can be 
counted by shifting the E-list At every new slot time point, the E-//sr will be right-shifted as it is shown in Figure 10. 
The S point E value of the previous SSW will no longer be counted by the scheduler. The M point E value of current 
SSW will be determined by value of M-counter. If the M-counter does not equal to 0, the E value of the M point of 
current SSW will be set as 0, and M-counfe/* will be decreased by 1 . If M-counter does equal to 0, then E value of M 

45 point will be set as 1 . 

[0037] A 6(t) function can be used to more formally represent E-list of an SSW at time v as follows: 

E - list(v) ={E V E 2 Ej } where E y = ( 7}.E)6[(v + fr) - 1] (2) 

50 

where v inside the expression (2) represents the S point. The shifting effects can be represented as: 

EjM=E H {v+V (3) 

55 

[0038] Expression (2) and (3) have demonstrated the generality of the traffic model. Variable v in expression (2) 
represents a viewpoint of interest, t represents the basic unit duration for data slots, control slots and delay lines. The 
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length of the E-list represents the operation window of the scheduler, which is defined by maximum time offset and 
maximum delay value. Expression (2) shows that the loading condition of a channel within the operation window can 
be exactly described, and expression (3) shows that the connection of such windows in consecutive time sequence. 
Therefore, the traffic condition of a channel can be accurately described. This model relies on only assumptions of 
5 synchronous transmission of data 29 and control 31 slots 30, and different integral numbers of the slot-duration-delay- 
lines 46. Specially, it is independent of the transmission frame of data and control slots. 

[0039] Therefore, the shifting process can take account of all the effects of previous burst transmission, but it is 
independent from the process of allocating the A point (arrival point) of an incoming burst. Accordingly, the receiving 
process at the ingress of the optical matrix 40 can be separated from the receiving process at the ingress of the 
10 electronic matrix 54. This can provide flexibility in system configuration of the synchronization process. 

[0040] By representing the loading status of a channel in terms of the E-list of a SSW, an efficient channel group 
scheduling process can be developed. The example of Figure 11 demonstrates how to use the SSWE-listto schedule 
the bursts. 

[0041] There are three bursts to be scheduled in Figure 11 : BL^ BL 2 , and BL 3 . The associated BHPs 32 arrive at 
15 different times. Burst BL-, is three slots in length and its BHP arrives between v 0 and v t . Burst BL 2 is four slots in length 
and its BHP arrives between v 1 and v^. Burst BL 3 is two slots in length and its BHP arrives between v 2 and v 3 . In the 
present example, it is assumed that there are three FDLs 46 in the system; they can delay two, four or six slot time 
periods respectively. Further, for this example, the maximum off-set of burst arrival time from its BHP arrival point is 
three slot periods. Therefore, in this example, there is a SSW window of nine slot periods (A max =3 and D max =6). Ac- 
20 cordingly, the SSI/Vtime sequence ranges from T 0 to T 9 . 

[0042] At Tq-vq, the SSW is empty and ready. T 3 corresponds to the maximum arrival time of bursts relative to S 
point Tq. T 5 , T 7 , and 7" 9 correspond to the exits of the fiber delay lines 46 relative to T 3 . They represent two, four, and 
six slot period delays respectively. T 9 is the M point; its M-counter is 0. Any time beyond T 9 is neither controlled nor 
managed. It should be noted that the FDL exit points are relative to its entry. 
25 [0043] At To=v 1t BL 1 should have completed scheduling. Now, T 2 denotes the arrival time of BL 1 relative to the S 
point. T 6 and T 8 denote the FDL exits relative to burst arrival time T 2 . Since all the points are empty, there is no 
need to delay the incoming burst. After the scheduling, T 2 , and T 4 are occupied. In Figure 9, Tj=1 is used to denote 

r,£=a 

[0044] When Tq^ 2 , tne previous SSW is right shifted, and BL 2 will be scheduled based on the shifted SSW. T 2 
30 corresponds to the arrival time of BL 2 relative to the S point. T 6 and T 8 denote the FDL exits relative to burst arrival 
time T 2 . Since T 2 , T 3 are occupied, BL 2 will be delayed. In choosing which FDL to use, two facts are important. The 
first consideration is whether there is a gap in the SSH/that can accommodate the burst from the exit of the FDL. The 
second consideration is whether there is an FDL entry available. In Figure 9, it is assumed that there is no entry available 
for the 2-slot-time FDL. 

35 [0045] It should be noted that when BL 2 is scheduled to be sent out at T 6> its span will excess the SSW window. For 
situations where the span of a scheduled burst exceeds the boundaries of the SSW, the M-counter variable of the M 
point is used to indicate the number of slots occupied the burst outside the SSW. In this case, M-counter=1, since BL 2 
is one slot over the window. 

[0046] When T"^^ the previous SSW would be right shifted again, and BL 3 will be scheduled based on the shifted 
40 SSW. T 3 denotes the arrival time of BL 3 relative to the S point. T 7 and T 9 denote the FDL exits relative to burst 
arrival time T 3 . Since T 3 and T 4 are not occupied, burst 3 can be scheduled as in Figure 9. 

[0047] As shown in the example of Figure 9, this procedure does not guarantee the order of the bursts. Although 
BL^ and its BHP arrive earlier than BL 3 , BL 3 sets out earlier from this node. 

[0048] Figure 12 and Figure 13 illustrate the modeling of FDLs 46 and the BHP micro-slots 34. The availability of 
45 either a FDL 46 or BHP micro-slot 34 can be a bottleneck for scheduling a burst. With concept of SSW, models for 
both FDLs 46 and the BHP micro-slots 34 can be easily created, 

[0049] The entry status of each fiber delay line 46 can be modeled over a window inside SSW. Figure 12 illustrates 
a model for a delay of D k E.dlt with m entries. For purpose of supporting SSW based scheduling, for every D k , it is 
necessary to know at every possible burst arrival time, whether there are entries available, and how long the gap is. 
50 Notice that this is needed because each FDL 46 is shared among channels. If an FDL 46 is used by one channel only, 
the SSW should be able to represent the status of its FDL 46. 

[0050] For every entry E k of a FDL Dy, there is an FDL Entry Status Window (FESW) associated with it. Figure 12 
shows m entries (f 1 through f m ) for delay Every FESW starts from the S point, and ends at the >4 /T7ax point, i.e., Tq, 
T p T Amax . A variable O is associated with every time point T } of the window. If T f .O x is equal to 1 , means that the 
55 f x (where x is between 1 and m) entry of FDL O k is empty at 7}. Otherwise, if T,.O x is equal to 0, means that the f x entry 
of FDL D k is occupied at 7}. 

[0051] Therefore, when a burst is switched to entry f x of an FDL D k at T h the O values of the FESW tor entry f x will 
be set to "0" from 7,-to T i+BL . V If 7} +flL _ f spans beyond T Amax> the A^.counter will be used; hence, O m will be set to 
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"0" from T, to T Amax and the A max -counter will be set to frBL-1 -A max . Like SSW, FESW will right shift once every slot 
cycle. The A max -counter records the number of slot cycles before T max f be set to 1 . Use of A max -counter is like the 
use of M-counter\n SSW windows. . 
[0052] The process of finding an FDL entry through FESW is simpler than finding a suitable gap through SSW, since 
all the matches would start from the burst arrival time point, and this point only. 

[0053] In the same way, the availability of micro-slots can be represented over a window inside SSW. Figure 13 
illustrates a Micro-Slot Status Window (MSSW). The MSSW starts from S point, and ends at L point. The L point is set 
to the M point, minus the minimum time offset between a data burst and its BHP. 

[0054] The MSSW records the status of control channel egress. From a scheduling point of view, for every slot time 
point from Sto L, the egress scheduler 52 needs to know if there are micro-slots 34 available. A micro-slot 34 can be 
usedto transmit BHPs as well as CPs. This can be achieved easily using the same mechanism as used to model FDLs' 
availability. Assuming that there is a time sequence Tq, T,, ...J l for every MSSW, a variable m*can be associated 
with every time point 7} of the window, specifying the availability of the associated time slot. If T,m ik is equal to 1 , the 
micro-slot Mstt k of T, is occupied. Otherwise, if T h m ik is equal to 0, the Mslt k micro-slot of T, is available. As with the 
SSLVand FESW, the value of m will be right shifted once every slot cycle. 

[0055] When a burst is scheduled to send out at slot time point T j} the egress scheduler 52 searches the [7}_ m/n _ 0/fee f- 
j ^segment of the MSSWwindow for a free micro-slot for its corresponding BHP. This search processing can 
savea little more time if a variable m, is used to represent the logical AND of all the m jk (k=1 r\) t that is 



m 



Mi 



25 [0056] If m j equals to 0, means that there is at least one micro-slot available in slot 7}, otherwise it means that all the 
micro-slots of the slot 7} have been used. 

[0057] In summary, a traffic model is disclosed for slotted burst over a switched optical channel. It is developed based 
on a basic fact that an FDL buffer capable optical switch could only monitor and manage a limited time window, and 
all the consequence of previous burst transmission can be counted by right shifting the window. With this model, burst 
30 transmission requests can be scheduled efficiently. Figure 1 4 shows timing relations between the windows in the model. 
The Slot Sequence Window (SSW) is defined on channel basis, the Micro-Slot Status Window (MSSW) and FDL Entry 
Status Window (FESW) are shared among the channels. The MSSW is on micro-slot basis, while FESW is per entry 

point and per FDL. 

[0058] All windows will be right shifted once per slot cycle. The right most value of previous slot will become past, 
35 and will not be used for any more. The left most value of the new window will be determined through recorded variables. 
M-counter and A max -counter are defined for this purpose. 

[0059] The slotted burst scheduling process can be implemented as shown in Figure 1 5. The basic idea is that by 
the time a BHP arrives, the system will convert the burst description in BHP (burst arrival time, burst length) into a bit 
sequence representation, referred to herein as Bseq. The Bseq tells the system in terms of SSW when the burst would 
arrive and the bursts length. If the Bseq expands over the M point of SSW, the rest of it will be recorded in a variable 
called B-counter, A very important technical feature of this invention is that by adjusting the Bseq. representation of 
burst arriving time and the B-counter, Bseq patterns would be able to take account the effects of different delays D^. 
Based on this, the scheduling method can consider a specific delay choice once per processing cycle, as described 
below, until a match been found. 

[0060] Advantageously, for a specific Bseq,, the processes for finding a match with SSW f FESW and MSSW are 
independent, and they can be implemented by combinatory circuit and can be executed in parallel. 
[0061] In step 100, when a Burst Header Packet (BHP) arrives, it holds a definition of the incoming burst: when it 
will arrive and how many slots it has. This information is converted into a bit sequence representation Bseq, and then 
use this bit representation to find out a suitable gap within the SSWs, together with the conditions in FESW window 
so and MSSI/Vwindow. The effects of FDL buffer can be counted by generating different Bseq representations of the same 
burst that has different arriving time. 

[0062] The Bseq representation of a burst is defined the same as the E-list over SSWwindow. Only in this case, 1 

represents that a slot time point is needed by a burst, and "0" to represent that the point is not needed. 

[0063] For worstncase scenarios in Figure 1 5, for one incoming burst, k bit representations are generated, namely, 

55 B seq 0 , Bseq 1 Bseq k . For a burst that spans over the SS Wwindow, a variable called B-counter records the bits that 

are outside the SSW. ^ . 

[0064] Since the length of a burst varies, it might be assumed that a bit representation be only generated when a 
burst has been received. In fact, the number of all possible bit representations is definite. It is decided by the size of 
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the SSW window. As it is shown in Figure 16, there are finite numbers of possible combinations of the incoming time 
slot point and its length within the SSW window. If a burst has slots coming after the M point, it will be regarded as an 
"infinite burst". For an infinite burst, the slot length after the Mpoint will be represented by the variable called B-counter. 
An infinite burst will occupy M point until B-counter becomes 0. An infinite burst can match with a SSW if and only if 
the SSW's A/f-point is not occupied. 

[0065] Therefore, in the preferred embodiment, all the possible bit representations of incoming bursts are saved, 
then retrieved when a burst comes using (start time, length) definition inside the BHP. In this way, the space complexity 
of this method is determined by size of SSW window. If the size of SSWis S ssw > then the number of stored patterns is 



[0066] Referring again to Figure 15, in step 102, Bseq is delayed by D t In the first iteration, D,= 0 (i.e., no delay). 
Simultaneous matching with the SSW, FESW and MSSW is performed in steps 104,106 and 108, respectively. 
[0067] In step 104, the matching is performed in the SSW. The number of SSW windows is equal to the number of 
data channels. The matching can be implemented using simple bit level logical operations. As shown in Figure 1 7, for 
an E-list={e 0t e r , .... e m ) and Bseq^foo, b 1t the matching can be performed by the operation: 



[0068] When M equals to 0, this E-list matches with the Bseq h otherwise, when M equals to 1 , the E-list does not 
match with the Bseq f . 

[0069] The number of SSWwindows is equal to the number of data channels. Therefore, there is a selection process 
for every Bseq h since there might be more than one such match. The selection process should choose the gap that 
fits the burst best, and leave the more space the possible. The match operation for every SSW can be done in parallel. 
[0070] In step 106, the matching is performed in the FESW. The same principle of step 104 applies to the match 
operation for FESW. For the whole system, the number of FESW is comparatively larger. If there are k levels of delays, 
and M entries for each delay, then there are kx M FESW windows. But for a processing cycle of the scheduling process, 
since every cycle only tries to match with one possible delay, the search space is M. They also can be done in parallel. 
[0071] In step 108, matching is performed in the MSSW. The search process for micro-slot is fairly simple. Once a 
Bseqi is given, the bu rst departure time is also defined, so by using the maximum and minimum time offset, the searching 
area of the MSSW windows is known. With the model of MSSW like in Figure 13, a deterministic result can soon be 
found. 

[0072] In step 110, the matching results are checked and, if the burst can be scheduled using a delay D, (step 112), 
the MSSW, FESW and SSW windows are updated in step 114. Otherwise, if a scheduling cannot occur in step 110, 
the delay D, is incremented in step 116. If the delay D, is within the delay range in step 116, the sequence of steps 
102-110 is repeated with the new D,and Bseqf, else, the burst is dropped in step 118, because it cannot be scheduled 
at any available delay. 

[0073] Figure 1 8 illustrates a block diagram of an egress scheduler 52. The BHP 32 is received by a Bseq generation 
circuit 1 30, which generates a Bseqf based on the length and time of arrival information of the BHP, as described above. 
A shift circuit 132 shifts the Bseqf according to the current delay (step 1 02 of Figure 1 3). The shifted Bseqf is input to a 
matching circuit 134. The matching circuit 134 performs three matches in parallel. The SSW matching circuit 136 
determines whether the current Bseq can fit in one of the SSW (there is one SSW for each data channel in the data 
channel group associated with the egress scheduler 52). The FESW matching circuit 1 38 determines whether a delay 
line with the current delay will be available when the burst arrives. The FESW information (there is one FESW for each 
entry into each delay) is available to all egress schedulers 52. The MSSW matching circuit 140 determines whether 
there is an available micro-slot 34 in the control channel associated with the egress scheduler 52. The MSSW infor- 
mation is specific to the associated egress scheduler 52. 

[0074] If there is a match in the matching circuit 134, i.e., if all three matching circuits 136, 138 and 140 match, 
information from the SSWs is sent to the Optical Matrix to control the path of the bursts. The information includes 
incoming burst channel ID, incoming slot ID, outgoing channel ID and outgoing slot ID and E value. If no match is 
found, another Bseqf bit pattern of different delay is generated to attempt another match for a different delay time. 
[0075] Figure 1 9 through Figure 31 illustrate a protocol architecture that may be used in conjunction with the optical 
burst network 4 described herein. As described in connection with Figure 1 , packets outside of the optical burst switched 
network are received at ingress routers 6; information in the packets are converted to bursts 28, which propagate 
through the optical burst switched network 4. At the egress routers 8, the bursts are converted back into packets. The 
protocol described herein provides format for representing information as it propagates through the optical burst 
switched network 4. 
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[0076] In this protocol architecture, each burst 28 is transmitted over one or more slots. Further, the BHPs 32 for 
various bursts 28 are transmitted within micro-slots 34 within a control slot 31. The protocol architecture describes a 
method of transmitting both bursts 28 through slot session and BHPs 32 and CPs through micro-slots. The scenarios 
of packets processing are described as in Figure 19. 

■ An ingress edge router 6 of network 4 distinguishes two interfaces. The "legacy pkt l/F" 5 refers the exterior IP 
interface, and the "edge l/F" 7 refers the interface to network 4. When an incoming IP packet arrives at the ingress 
edge 6 of network 4, it would be forwarded to an interface 7 based on its destination address; 

■ At an interface 7, the processing are divided into data channel and control channel. On data channel, the ingress 
functions for the sub-packet layer, burst layer, SSSL-D (Service Specific Slot Layer for Data channel) layer and 
CSL (Common Slot Layer) are performed. On control channel , the ingress functions for BHP (Burst Header Packet), 
IP (Internet Protocol), SSSL-C (Service Specific Slot Layer for Control channel) and CSL (Common Slot Layer) 
are performed. 

■ Within core router 1 0, data bursts 28 on data channel 1 6 or 21 will not be processed. The IP and BHP are processed. 
The functions of BHP, IP, SSSL-C and CSL for control channel will be performed. 

■ At egress edge interface 9, egress functions of sub-packet layer, burst layer, SSSL-D and CSL are performed for 
data bursts 28. The exterior IP packets will be disassembled completely. In control channels 17 or 18, the BHP, 
SSSL-C and CSL are performed for BHPs 32; 

■ The disassembled exterior IP packets be sent to corresponding "legacy pkt l/F" 11 using its original IP address; 

[0077] In the following the structure of the protocols are presented. Figure 20 illustrates a diagram of a slot of infor- 
mation in a common slot format. The common slot format (or Common Slot Layer, CSL) is designed for both data 
(bursts) and control (BHP) slots. The common slot layer has six parts: Guarding time and bit sync; CSL preamble; 
SSSL (Service Specific Slot Layer) preamble, Slot Payload and Slot check sum. These fields are described in Table 1 . 



Table 1 



Common Slot Layer Fields 


Guard time 


The guard time is used as an edge to trigger the optical matrix synchronizers. The 
guard time has a maximum length. If the needed guarding time is less than the 
maximum length, it can be filled by bit sync. 


Bit synchronization pattern 


Bit sync pattern is necessarily to extract clock synch information at the transceiver. 
This pattern starts immediately after the guard time. In the preferred embodiment, bit 
synchronization pattern is minimum of 128 bits. 


CSL preamble 


The overhead information common for both data and control slot. It is also called the 
header of Common Slot Layer (CSL). 


SSSL preamble 


SSSL Preamble is the header of Service Specific Slot Layer (SSSL). The SSSL layer 
can be one of two types: the SSSL_D for a data channel and the SSSL_C for a control 
channel. Their header information is different 


SSSL Payload 


In a data slot, SSSL payload carries the data burst traffic. In control slot, the SSSL 
payload carries the Burst Head Packets (BHPs) and other network control and 
management messages (CPs). 


SSSL Payload Check Sum 


Used for error checking purposes 



[0078] The CSL preamble contains three fields. These are described in Table 2. 



Table 2 



Common Slot Layer Preamble Fields 


Slot Sync 


Slot sync is used for slot boundary recognition 
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Table 2 (continued) 



Common Slot Layer Preamble Fields 


Slot Type 


Slot type field indicates the type of a slot. Four types of slots have been identified, they are data 
slot, control slot, idle slot and OAM (operation, administration and maintenance) slot. Idle slots are 
sent out when there is no data to send. OAM slots are used by optical transceiver for transmission 
OAM functions only. 


OAM address 


OAM address refers to the transceiver where the loop back slot is going to be terminated. 



[0079] As described in Table 1 , the SSSL Preamble varies depending on whether the information in the SSSL Payload 
is either data or control information. If the information is data, a SSSL_D Preamble is used; if the information is control 
information, a SSSL_C Preamble is used. Figure 21 illustrates a SSSL_D for data information. The fields of the SSSL_D 



are shown in Table 3. 


Table 3 


SSSL_D Preamble Fields 


Slot Session ID 


Slot Session I D identifies the slots that transmit the same data package. Within the optical 
burst network, a slot session is used to transmit a data burst. The SSID would be the 
same as Burst ID. 


Slot Session Length 


Specifies the length of the slot session in number of slots. 


Slot Sequence Number 


It indicates the slot sequence number in the session. The initial sequence number is set 
as the total length of the session, then decrease to 1 . At the receiving end, if SSN-1=0, 
then no more slots are to come. 


Slot Session Type 


Indicates slot type for quality of service purposes. 


Header Checksum 


A check sum used for SSSL headers. 



[0080] As in the embodiment shown above, the control channel 18 is responsible for transmitting BHPs and CPs. 
CP packets may include LCP (Link Control Protocol), IPCP (Internet Protocol Control Protocol), MPLSCP (Multi-Pro- 
tocol Label Switching Control Protocol) and ICMPv4 (Internet protocol Control Message Protocol), and so on. The 
Control-channel Service Specific Slot Layer (SSSL_C) is defined based on this feature. 

[0081] Figure 22 illustrate a diagram of a SSSL_C format. As shown in Figure 22, to transmit BHP and CPs, the 
SSSL_C payload is divided into micro-slots, and is partitioned into a CP window part and a BHP window part. The CP 
window part is allocated for transmitting network control information (CPs) and the BH P window part is used to transmit 
BHPs. In terms of packet processing, the difference is that for every BHP, the micro-slot contains a complete IPV4/PPP 
encapsulation (PPP stands for Point to Point Protocol). For CPs, under most cases a single CP can be transmitted 
over multiple micro-slots. 

[0082] To facilitate transferring CPs and BHPs, the respective windows can change size if necessary for optimal 
transfer of the control information. It is assumed that a change in the partition between the CP and BHP windows would 
happen after or before a completion of a CP packet so that there in no change of the CP window size while a CP packet 
is in transmitting. 

[0083] The CP window and BHP window size can also be statically set by management configuration functions. The 
CP window assumes to carry all network control information other than BHPs, including possible control messages in 
Iayer2 like LCP (Link Control Protocol) messages for IPV4 (IPCP: Internet Protocol Control Protocol) and MPLS (MPLS- 
CP: Multi-Protocol Label Switching Control Protocol). 

[0084] The fields of the SSSL_C Preamble are shown in Figure 23 and Table 4. 



55 
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Table 4 



SSSL_C Preamble Fields 


Number of CP micro-slots 


Assuming that the CP window always start from 0 micro- 
slot, this field defines the number of micro-slots (#cp) 
that are used for transmitting CP messages. The CP 
window would be equal to #cp, the BHP window would 
be equal to number of micro slots minus #cp (#number 
of micro-slots - #cp). 


Type of micro slots and protocol encapsulation 


Specifies types micro slots, and possible encapsulation 
of protocols. It also needs to distinguish if IPV4/PPP/ 
HDLC or IPV4/MPLS/PPP/HDLC encaosulation is u<?e>d 

1 1 ^ will ir ■* ^SmJl 1 I I'll L^UW w 1 I^CLUOU 1 CI 1 1 \J 1 1 1 O UOCU. 


Source address, destination address and Micro-Slot 
Session ID (MSSID) 


These fields are used to uniquely identify the CPs within 
the optical burst network. Source address and 
destination address are IPV4 addresses. MSSID is an 
integer managed by the source node. Micro-Slot 
Session 1 D identifies the slots that transmit the same CP 
between the source and destination. 


Micro-slot Session Length (MSL) 


Defines the length of CP in number of slots 


Micro-slot Session Sequence NUMber (MSSNUM) 


Indicates the micro-slot sequence number in the 
session. 


Micro-slot Map (msmap) 


Indicates which micro-slot is not used in the control slot. 
The number of bits in this field equals exactly the number 
of micro slots of a control slot. Value 1 represents used, 
0 represents empty. 



[0085] The transmission of BHP and CP is shown as in Figure 24. Depending on the size of the CP window (#cp), 
a CP packet will occupies 



35 length^of _CP 

| # cp x {CP _ payload _ length) 

slots in the control channel. A BHP will use one of the micro-slot in the BHP window of the slot. As shown in Figure 
24, each BHP and associated information is contained in a micro-slot with the BHP window; a CP and associated 
40 information may be split between CP windows of a sequence of slots. 

[0086] Figures 25 through 28 illustrate transmission of a burst 28. The overall structure is shown in Figure 28. To 
transmit a data burst, a burst header (Figure 25 and as described in Table 5) is first added to the burst 28. The entire 
burst is divided into segments. The segments then are attached to the SSSL preamble, and are transmitted by the slots. 

45 Table 5 



Burst Layer Fields 


Burst ID 


Burst ID is a number. It should be unique per network edge. Burst ID is also present in 
BHP. When transmitting a data burst, the Slot Session ID (SSID) of SSSL will be set as 
the Burst ID. 


Burst Type 


Burst types may be distinguished for quality of service requirements at the network edge. 


Burst length 


It indicates burst length in bytes. 

Burst length = length of Burst Id field + length of Burst type field + length of Burst length 
filed + length of number of sub- 
packet filed + length of sub-packet 1 + ... + length of subpacket k 


Number of subpackets 


It indicates the number of sub-packets 
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[0087] Figure 25 through Figure 28 are related to processing of burst segmentation and assembly, error detection 
and flow control. A data burst is composed of many network layer packets. For the purpose of supporting multiple 
network protocols, PPP protocol is employed to support transportation of network packets over the data channel. For 
burst switching, it is preferable to not use bit stuffing, because this would require allocating space for the worst-case 
5 bit stuffing scenario, which could be awkward for variable length IP packets, especially since many of them may be 
cascaded together to form the super packet. Therefore, length indicator framing is chosen as a preferred method for 
layer 2 framer. 

[0088] Figure 27 show the organization of a super-packet. At an ingress router, incoming IP packets (or other data 
format) are received and a PPP header and packet length indicator are added to the packets to form a sub-packet, 
10 shown in Figure 26. In Figure 27, the super-packet is formed by accumulating all sub-packets associated with a burst 
and adding a burst preamble (shown in detail in Figure 28). 

[0089] BHP/CP encapsulation is shown in connection with Figure 29 to Figure 31 . Both BHP and CPs are transmitted 
in the control slots that are treated as a PPP link. The encapsulation of BHP and CP are different, as described below. 
[0090] As shown in Figure 29, a BHP is a fixed length packet. It should always occupy one micro-slot of SSSL_C. 
is Therefore no length indicator is necessary. The fields for a BHP are provided in Tables 6 and 7. 



Table 6 



BHP IPV4/MPLS/PPP Encapsulation 


Protocol Field (PPP header field) 


This is a two octetfield, and its value identifies the payload encapsulated in the 
Information field of the packet. The structure of this field should be consistent 
with the ISO 3309 extension mechanism for address fields. 


MPLS Field 


Contains the MPLS label as defined by IETF MPLS working group 


IPV4 Header 


It is a standard IPV4 header except that all the options will not be used. To 
support BHP, the PROTOCOL field of IPV4 header may be extended. 



[0091] The BHP Payload is shown in Figure 30 and described in Table 7. All the BHPs will be transported in a micro- 
slot by using IP/MPLS/PPP encapsulation as shown in Figure 29. 

30 

Table 7 



BHP Payload 


Ingress Data Channel Group ID (IDCG) 


Indicator of ingress data channel group 


Ingress Data Channel (IDC) 


Indicator of ingress data channel, it is within a data channel group 


Burst ID (BID) 


The burst ID is a sequence number that is unique per edge. The BID is 
present in both the BHP and data burst, can be used for correlation 
purposes. 


Burst DURation (BDUR) 


The number of slots before the corresponding burst would arrive. 


Burst time offset (BOFFSET) 


Indicates burst offset in terms of how many slots before the burst arrives 
the optical matrix 



[0092] Figure 31 illustrates encapsulation of the control packets (CPs). Control packets may be of variable length. 
The length of a CP is indicated by the length field. The protocol field indicates the protocol type of the CP. The CP 
Payload carries the CP information. The padding field includes unused bits. 

[0093] Figure 32 illustrates a timing diagram showing in-band transmission of control and data bursts on a single 
channel. An in-band implementation uses the same basic control/data structure as described above; however, slots 
31 of BHPs 32 are transmitted on a common channel with the associated data bursts 28. In the illustrated embodiment, 
slots 30 are grouped into superframes. Control slots 31 and data slots 29 may be arbitrarily assigned within a super- 
frame. Alternatively, the control slots 31 could be placed are regular positions within a superframe. Bursts 28 may span 
multiple superframes. Multiple control slots 31 may be present within a single superframe. 

[0094] As above, a control slot 31 is divided into multiple microslots 34. Each microslot 34 may store a BHP 32 (or 
a control packet). Each BHP 32 is associated with a burst 28 on the same channel, so long as the timing relationship 
of the burst and its associated BHP is between A^ and A max . 

[0095] One advantage of using in-band transmission of control and data is that the architecture is closer to a classic 
Internet protocol network, where the control header and data payload are transmitted together. 
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[0096] Figure 33 illustrates a I/O port 14 for use with in-band transmission. For each channel, I/O port 14 includes 
interface 150, data slot processor 152 and control slot processor 154. Interface 150 separates the data in control slots 
31 from data slots 29. Identification of control slots 31 could be accomplished, for example, by a unique synchronization 
pattern. When a control slot is identified, the data is transferred to the control slot processor 154 for preparing the data 
5 for transmission to the electronic control circuit 20. Similarly, data slots 29 are sent to data slot processor 152 for 
preparation for entering the optical switch 22. 

[0097] Importantly, the protocol described above can be used for either in-band or out-band transmission modes. 
[0098] Although the Detailed Description of the invention has been directed to certain exemplary embodiments, 
various modifications of these embodiments, as well as alternative embodiments, will be suggested to those skilled in 
10 the art. The invention encompasses any modifications or alternative embodiments that fall within the scope of the 
Claims. 



Claims 

15 

1 . A method of scheduling the switching of data bursts through a router in an optical burst switched network, wherein 
data bursts are received by the router over a first set of plurality of optical transmission lines and are switched to 
a second set of optical transmission lines, wherein the data bursts are communicated over said first and second 
sets of optical transmission lines over multiple channels using synchronous fixed length slots, each burst occupying 
20 one or more slots in a channel, comprising the steps of: 

generating current scheduling bit patterns for respective outgoing channels indicating which slots in each 
outgoing channel are already scheduled to transmit a data burst within a predetermined time window relative 
to a current time point; 

25 generating an incoming burst bit sequence for an incoming burst indicating which slots within said predeter- 

mined time window would be occupied by said incoming burst relative to a current time point; and 
comparing said incoming burst bit sequence with said current scheduling bit patterns to determine whether 
said incoming burst can be scheduled for transmission on one of said outgoing channels. 

30 2. The method of claim 1 wherein said router further includes one or more delay lines, each delay line having an 
associated delay of one or more slot periods, and further comprising the steps of: 

for each unique delay provided by the delay lines, generating a delayed incoming burst bit sequence indicating 
which slots would be occupied by said incoming burst if said incoming burst were delayed by said unique 
35 delay; and 

comparing said delayed incoming burst bit sequences with said current scheduling bit patterns to determine 
whether said incoming burst can be scheduled for transmission on one of said outgoing channels after at least 
one of said delays. 

40 3. The method of claim 1 wherein each data burst is preceded by an associated control header indicating the time 
of arrival and length of said associated data burst and further comprising the step of generating a control header 
scheduling bit pattern for indicating whether a control slot associated with one or more of said outgoing channels 
is fully occupied. 

45 4. The method of claim 1 wherein said router further includes one or more delay lines, each delay line having an 
associated delay of one or more slot periods, and wherein each data burst is preceded by an associated control 
header indicating the time of arrival and length of said associated data burst, and further comprising the steps of: 

generating a control header scheduling bit pattern for indicating whether a control slot associated with one or 
so more of said outgoing channels is fully occupied. 

generating delay line scheduling bit sequences for respective delay lines indicating which slots in each delay 
line are already scheduled to transmit a data burst within a predetermined delay time window relative to a 
current time. 

for each unique delay provided by the delay lines, generating a delayed incoming burst bit sequence indicating 
55 which slots would be occupied by said incoming burst if said incoming burst were delayed by said unique delay; 

comparing said delayed incoming burst bit sequences with said current scheduling bit patterns to determine 
whether said incoming burst can be scheduled for transmission on one of said outgoing channels after at least 
one of said delays; 
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comparing said incoming burst bit sequence with said delay line scheduling bit patterns to determine whether 
said incoming burst can be scheduled for transmission on one of said delay lines; and 
determining from said control header scheduling bit pattern whether a control header bit associated with the 
incoming data burst can be scheduled between a minimum and maximum offset. 

An optical burst switched network including one or more interconnected routers, one or more of said routers com- 
prising: 

an optical matrix coupled between a first set of optical transmission lines and a second set of optical trans- 
mission lines, wherein the data bursts are communicated over said first and second sets of optical transmission 
lines over multiple channels using synchronous fixed length slots, each burst occupying one or more slots in 
a channel; 

scheduling circuitry for scheduling the switching of data bursts through the optical matrix, comprising: 

circuitry for generating current scheduling bit patterns for respective outgoing channels indicating which 
slots in each outgoing channel are already scheduled to transmit a data burst within a predetermined time 
window relative to a current time point; 

circuitry for generating an incoming burst bit sequence for an incoming burst indicating which slots within said 
predetermined time window would be occupied by said incoming burst relative to a current time point; and 
circuitry for comparing said incoming burst bit sequence with said current scheduling bit patterns to determine 
whether said incoming burst can be scheduled for transmission on one of said outgoing channels. 

The network of claim 5 wherein each router further includes one or more delay lines, each delay line having an 
associated delay of one or more slot periods, and wherein said scheduling circuitry further comprises: 

circuitry for generating a delayed incoming burst bit sequence for each unique delay provided by the delay 
lines, indicating which slots would be occupied by said incoming burst if said incoming burst were delayed by 
said unique delay; and 

circuitry for comparing said delayed incoming burst bit sequences with said current scheduling bit patterns to 
determine whether said incoming burst can be scheduled for transmission on one of said outgoing channels 
after at least one of said delays. 

The network of claim 5 wherein each data burst is preceded by an associated control header indicating the time 
of arrival and length of said associated data burst and wherein said scheduling circuitry further comprises circuitry 
for generating a control header scheduling bit pattern for indicating whether a control slot associated with one or 
more of said outgoing channels is fully occupied. 

The network of claim 5 wherein said router further includes one or more delay lines, each delay line having an 
associated delay of one or more slot periods, and wherein each data burst is preceded by an associated control 
header indicating the time of arrival and length of said associated data burst, and wherein said scheduling circuitry 
further comprises: 

circuitry for generating a control header scheduling bit pattern for indicating whether a control slot associated 
with one or more of said outgoing channels is fully occupied. 

circuitry for generating delay line scheduling bit sequences for respective delay lines indicating which slots in 
each delay line are already scheduled to transmit a data burst within a predetermined delay time window 
relative to a current time. 

circuitry for generating a delayed incoming burst bit sequence for each unique delay provided by the delay 
lines, indicating which slots would be occupied by said incoming burst if said incoming burst were delayed by 
said unique delay; 

circuitry for comparing said delayed incoming burst bit sequences with said current scheduling bit patterns to 
determine whether said incoming burst can be scheduled for transmission on one of said outgoing channels 
after at least one of said delays; 

circuitry for comparing said incoming burst bit sequence with said delay line scheduling bit patterns to deter- 
mine whether said incoming burst can be scheduled for transmission on one of said delay lines; and 
circuitry for determining from said control header scheduling bit pattern whether a control header bit associated 
with the incoming data burst can be scheduled between a minimum and maximum offset. 
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9. An optical router for routing data bursts, comprising: 

an optical matrix coupled between a first set of optical transmission lines and a second set of optical trans- 
mission lines, wherein the data bursts are communicated over said first and second sets of optical transmission 
lines over multiple channels using synchronous fixed length slots, each burst occupying one or more slots in 
a channel; 

scheduling circuitry for scheduling the switching of data bursts through the optical matrix, comprising: 

circuitry for generating current scheduling bit patterns for respective outgoing channels indicating which 
slots in each outgoing channel are already scheduled to transmit a data burst within a predetermined time 
window relative to a current time point; 

circuitry for generating an incoming burst bit sequence for an incoming burst indicating which slots within said 
predetermined time window would be occupied by said incoming burst relative to a current time point; and 
circuitry for comparing said incoming burst bit sequence with said current scheduling bit patterns to determine 
whether said incoming burst can be scheduled for transmission on one of said outgoing channels. 

10. The router of claim 9 wherein each router further includes one or more delay lines, each delay line having an 
associated delay of one or more slot periods, and wherein said scheduling circuitry further comprises: 

circuitry for generating a delayed incoming burst bit sequence for each unique delay provided by the delay 
lines, indicating which slots would be occupied by said incoming burst if said incoming burst were delayed by 
said unique delay; and 

circuitry for comparing said delayed incoming burst bit sequences with said current scheduling bit patterns to 
determine whether said incoming burst can be scheduled for transmission on one of said outgoing channels 
after at least one of said delays. 

11. The router of claim 9 wherein each data burst is preceded by an associated control header indicating the time of 
arrival and length of said associated data burst and wherein said scheduling circuitry further comprises circuitry 
for generating a control header scheduling bit pattern for indicating whether a control slot associated with one or 
more of said outgoing channels is fully occupied. 

12. The router of claim 9 wherein said router further includes one or more delay lines, each delay line having an 
associated delay of one or more slot periods, and wherein each data burst is preceded by an associated control 
header indicating the time of arrival and length of said associated data burst, and wherein said scheduling circuitry 
further comprises: 

circuitry for generating a control header scheduling bit pattern for indicating whether a control slot associated 
with one or more of said outgoing channels is fully occupied. 

circuitry for generating delay line scheduling bit sequences for respective delay lines indicating which slots in 
each delay line are already scheduled to transmit a data burst within a predetermined delay time window 
relative to a current time. 

circuitry for generating a delayed incoming burst bit sequence for each unique delay provided by the delay 
lines, indicating which slots would be occupied by said incoming burst if said incoming burst were delayed by 
said unique delay; 

circuitry for comparing said delayed incoming burst bit sequences with said current scheduling bit patterns to 
determine whether said incoming burst can be scheduled for transmission on one of said outgoing channels 
after at least one of said delays; 

circuitry for comparing said incoming burst bit sequence with said delay line scheduling bit patterns to deter- 
mine whether said incoming burst can be scheduled for transmission on one of said delay lines; and 
circuitry for determining from said control header scheduling bit pattern whether a control header bit associated 
with the incoming data burst can be scheduled between a minimum and maximum offset. 

13. The router of claim 9 wherein said comparing circuitry compares said incoming burst bit sequence with said delay 
line scheduling bit patterns to determine whether said incoming burst can be scheduled for transmission on one 
of said delay lines simultaneously with said determining circuitry determining from said control header scheduling 
bit pattern whether a control header bit associated with the incoming data burst can be scheduled between a 
minimum and maximum offset. 
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14. A method of modeling communications traffic at a router in an optical burst switched network, wherein data bursts 
are received by the router over a first set of plurality of optical transmission lines and are switched to a second set 
of optical transmission lines, wherein the data bursts are communicated over said first and second sets of optical 
transmission lines over multiple channels using synchronous fixed length slots, each burst occupying one or more 

5 slots in a channel, comprising the steps of: 

generating current scheduling bit patterns for respective outgoing channels indicating which slots in each 
outgoing channel are already scheduled to transmit a data burst within a predetermined time window relative 
to a current time point; 

10 for each current scheduling bit pattern, generating an overflow value indicating a number of slots outside the 

predetermined time window that are occupied by a data burst starting within the time window. 

15. The method of claim 14 and further comprising the step of shifting bits in said current scheduling bit patterns by 
one bit position to generate new scheduling bit patterns for said outgoing channels responsive to a slot clock signal . 

15 

16. The method of claim 14 wherein said router includes one or more delay lines for delaying an incoming data burst 
by an amount equal to an integral number of slot periods, and further comprising the steps of: generating current 
delay line scheduling bit patterns for respective delay lines indicating which slots in each delay line channel are 
already scheduled to buffer a data burst within said predetermined time window relative to said current time point; 

20 and 

for each current delay line scheduling bit pattern, generating an delay line overflow value indicating a number 
of slots outside the predetermined time window that are occupied by a data burst starting within the time window. 

17. The method of claim 16 and further comprising the step of shifting bits in said current delay line scheduling bit 
25 patterns by one bit position to generate new delay line scheduling bit patterns for said outgoing channels responsive 

to a slot clock signal. 

18. A router for use in an optical burst switched network, comprising: 

30 circuitry for modeling communications traffic, wherein data bursts are received by the router over a first set of 

plurality of optical transmission lines and are switched to a second set of optical transmission lines, wherein 
the data bursts are communicated over said first and second sets of optical transmission lines over multiple 
channels using synchronous fixed length slots, each burst occupying one or more slots in a channel, compris- 
ing: 

35 

circuitry for generating current scheduling bit patterns for respective outgoing channels indicating which 
slots in each outgoing channel are already scheduled to transmit a data burst within a predetermined time 
window relative to a current time point; and 

40 circuitry for generating an overflow value for each current scheduling bit pattern, indicating a number of slots 

outside the predetermined time window that are occupied by a data burst starting within the time window. 

19. The router of claim 18 and further comprising the circuitry for shifting bits in said current scheduling bit patterns 
by one bit position to generate new scheduling bit patterns for said outgoing channels responsive to a slot clock 

45 signal. 

20. The router of claim 18 and further comprising: 

circuitry for generating an incoming data burst bit pattern of slots within said predetermined time window oc- 
50 cupied by an incoming data burst relative to said current time; and 

circuitry for generating an incoming data burst overflow value representing a number of slots outside of said 
predetermined time window occupied by said incoming data burst. 

21. The router of claim 18 wherein said router includes one or more delay lines for delaying an incoming data burst 
55 by an amount equal to an integral number of slot periods, and further comprising: 

circuitry for generating current delay line scheduling bit patterns for respective delay lines indicating which 
slots in each delay line channel are already scheduled to buffer a data burst within said predetermined time 
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window relative to said current time point; and 

circuitry for generating an delay line overflow value, for each current delay line scheduling bit pattern, indicating 
a number of slots outside the predetermined time window that are occupied by a data burst startinq within the 
time window. 

22. A method of communicating information in an optical burst switched network, comprising the steps of: 

aggregating related incoming network packets into bursts; 

for each burst, generating a burst header identifying a time of arrival and a destination forthe associated burst- 
organizing each burst into one or more data information groups and organizing groups of burst headers into 
control information groups, wherein both data and control information groups have a common predefined 
length; 

wherein both data and control information groups have a predefined common information area with informa- 
tion relating to both data and control information groups, including information identifying the information group as 
either a control information group or a data information group. 

23. The method of claim 22 wherein data information groups have a data-specific function area for processing infor- 
mation related to data information groups. 

24. The method of claim 22 wherein control information groups have a control-specific function area for processing 
information related to control information groups. 

25. The method of claim 24 wherein said control information group includes a payload area for transporting both burst 
headers and control messages. 

26. The method of claim 25 wherein said control-specific function area includes information identifying the division of 
the payload area between said group of burst headers and said control messages. 

27. A network of interconnected routers for communicating information in an optical burst switched network, wherein 
one or more of said routers comprise; 

circuitry for aggregating related incoming network packets into bursts; 

circuitry for generating a burst header for each burst identifying a time of arrival and a destination for the 
associated burst; and 

circuitry for organizing each burst into one or more data information groups and organizing groups of burst 
headers into control information groups, wherein both data and control information groups have a common 
predefined length and 

wherein both data and control information groups have a predefined common information area with information 
relating to both data and control information groups, including information identifying the information group as 
either a control information group or a data information group. 

28. A method of communicating information in an optical burst switched network, comprising the steps of: 

transmitting multiple channels of information over an optical transmission medium; 
for each channel: 

transmitting data bursts as series of one or more data slots; 

transmitting groups of control headers in a control slot, each of said control headers containing routing 
information for a data burst in the same channel. 

29. The method of claim 28 wherein each control header precedes its associated data burst by at least a predetermined 
minimum time. 

30. The method of claim 29 wherein each of the control headers precedes its associated data burst by no more than 
a predetermined maximum time. 
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31. The method of claim 28 wherein said data and control slots are arranged in one or more superframes. 

32. The method of claim 31 wherein a burst may span two or more superframes. 

5 33. The method of claim 31 wherein a control slot can be placed in an arbitrary slot position within a superframe. 

34. A router for communicating information in an optical burst switched network, comprising: 

circuitry for transmitting multiple channels of information over an optical transmission medium, including, for 
10 each channel: 

circuitry for transmitting data bursts as series of one or more data slots; and 

circuitry for transmitting groups of control headers in a control slot, each of said control headers containing 
routing information for a data burst in the same channel. 

15 

35. The router of claim 34 wherein said data and control slots are arranged in one or more superframes. 

36. The router of claim 35 wherein a burst may span two or more superframes. 

20 37. The router of claim 35 wherein a control slot can be placed in an arbitrary slot position within a superframe. 
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